**PROJETO PIII: FORNO MICRO-ONDAS – SISTEMAS DIGITAIS**

* Lucas Henrique do Nascimento Silva (lhns3)
* Breno Gabriel de Melo Lima (bgml)
* Ricardo Bizerra de Lima Filho (rblf)
* Severino Murilo da Silva (sms6)

1) O projeto tem como objetivo construir um sistema com diversos blocos de construção do forno de micro-ondas que será implementado como circuito digital em um FPGA, em que o usuário possa programar o tempo de cozimento desejado e tenha controles básicos de um forno usual. O sistema recebe como entrada o tempo em que o micro-ondas vai trabalhar por dez chaves na placa FPGA (corresponde ao teclado numérico), e, com a porta fechada ao pressionar o botão ‘iniciar’ o tubo de magnetron (inicializa a emissão das micro-ondas) é ativado e os dígitos começam a contagem decrescente até o 0 (tempo em o alimento para de ser cozido), a menos que o botão de ‘limpar’ seja pressionado em algum momento da contagem e os dígitos vão imediatamente para 0, além desses também há o input de ‘parar’, que para momentaneamente a emissão das ondas, e ao apertar ‘iniciar’ a contagem decresce de onde parou e o alimento volta a ser cozido. Para melhor entendimento o problema é decomposto em três níveis de hierarquia com quatro blocos funcionais no nível 2, além de serem tomadas decisões estratégicas para a simplificação de soluções.

a) São o **timer de minutos/segundos** que conta em ordem decrescente a cada um segundo o período de cozimento, no projeto, para facilitar o carregamento e exibição dos dados, é escolhido um contador BCD em cascata, a **entrada de timer e controle** que tem como função receber os inputs: teclado numérico, clock e enable e, com eles, repassar a lógica na forma necessária para o timer a partir de blocos de codificação, divisão de frequência, multiplexação e contagem, o **controle de magnetron** que controla a saída do tubo de magnetron e inicia a emissão das micro-ondas, para manter a saída ativada após o botão ‘ligar’ ser solto é necessário a junção de lógica combinacional com Latch SR e o **decodificador/driver de 7 segmentos** o qual decodifica os três dígitos BCD, aciona os displays de LED de 7 segmentos e fornece funções de eliminação de zeros à frente e pode ser construído com três circuitos decodificador/driver 7447.

b) Nesse caso, sem inputs, o clock de 100 Hz funciona normalmente, mas nenhuma das 10 chaves é pressionada, nem o ‘enablen’ é ativado (no caso, mantém em nível alto), com o ‘enablen’ desativado o clock do contador do temporizador recebe 0.

c) Quando qualquer botão é pressionado com o magnetron desligado a entrada do clock contador tem de receber uma única borda de subida positiva alguns milissegundos após cada tecla ser pressionada. Entretanto, ele não pode receber nenhuma outra borda de subida até que a tecla seja solta, essa técnica de impedir múltiplas bordas é a eliminação do efeito de trepidação do contato. Para isso é gerando um pequeno delay antes de criar a borda de subida a partir de um contador de três bits não reciclável.

2) Todos os módulos de nível 3 foram testados por bancadas de testes e as formas de ondas obtidas foram como o esperado. Os circuitos incluem: contador\_mod10, contador\_mod6, latch\_sr, comb\_logic (lógica combinacional do magnetron), mux, encoder, counter\_freq e counter\_non\_recycling.

3) Todos os blocos digitais do nível 2 foram integrados, implementados e testados com bancadas de testes, e, com elas obtivemos formas de ondas de acordo com o esperado. Os blocos são: magnetron, entrada\_timer\_controle, decoder\_7seg, timer\_min\_sec.

4)

5)

6)